1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75
#![allow(non_camel_case_types, non_snake_case)]
use crate::decl::*;
use crate::guard::*;
use crate::kernel::{ffi, privs::*};
use crate::prelude::*;
impl_handle! { HPIPE;
/// Handle to an
/// [anonymous pipe](https://learn.microsoft.com/en-us/windows/win32/ipc/anonymous-pipes).
/// Originally just a `HANDLE`.
}
impl kernel_Hpipe for HPIPE {}
/// This trait is enabled with the `kernel` feature, and provides methods for
/// [`HPIPE`](crate::HPIPE).
///
/// Prefer importing this trait through the prelude:
///
/// ```no_run
/// use winsafe::prelude::*;
/// ```
pub trait kernel_Hpipe: Handle {
/// [`CreatePipe`](https://learn.microsoft.com/en-us/windows/win32/api/namedpipeapi/nf-namedpipeapi-createpipe)
/// function.
///
/// Returns handles to the read and write pipes.
#[must_use]
fn CreatePipe(
attrs: Option<&mut SECURITY_ATTRIBUTES>,
size: u32,
) -> SysResult<(CloseHandleGuard<HPIPE>, CloseHandleGuard<HPIPE>)>
{
let (mut hread, mut hwrite) = (HPIPE::NULL, HPIPE::NULL);
unsafe {
bool_to_sysresult(
ffi::CreatePipe(
hread.as_mut(),
hwrite.as_mut(),
attrs.map_or(std::ptr::null_mut(), |lp| lp as *mut _ as _),
size,
),
).map(|_| (CloseHandleGuard::new(hread), CloseHandleGuard::new(hwrite)))
}
}
/// [`ReadFile`](https://learn.microsoft.com/en-us/windows/win32/api/fileapi/nf-fileapi-readfile)
/// function.
///
/// Returns the number of bytes read.
///
/// Note that asynchronous reading – which use the
/// [`OVERLAPPED`](crate::OVERLAPPED) struct – is not currently supported by
/// this method, because the buffer must remain untouched until the async
/// operation is complete, thus making the method unsound.
fn ReadFile(&self, buffer: &mut [u8]) -> SysResult<u32> {
unsafe { HFILE::from_ptr(self.ptr()) }
.ReadFile(buffer)
}
/// [`WriteFile`](https://learn.microsoft.com/en-us/windows/win32/api/fileapi/nf-fileapi-writefile)
/// function.
///
/// Returns the number of bytes written.
///
/// Note that asynchronous writing – which use the
/// [`OVERLAPPED`](crate::OVERLAPPED) struct – is not currently supported by
/// this method, because the buffer must remain untouched until the async
/// operation is complete, thus making the method unsound.
fn WriteFile(&self, data: &[u8]) -> SysResult<u32> {
unsafe { HFILE::from_ptr(self.ptr()) }
.WriteFile(data)
}
}